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D0AI*-D I RECTORY VIRTUAL CACHE MEMORY AMD METHOD 
FOR CONTROL THEREOF 

The present invention relates to a dual-directory 
virtual cache memory which can be accessed directly using 
a virtual address without performing an address 
conversion operation, and to a method for controlling the 
5 same. 

A cache system has an important effect on the 
improvement in performance of a microprocessor. In 
particular, the use of a virtual cache is growing more 
important day by day to reduce the time required for 

10 converting a virtual address into a physical address, and 
accessing the cache using the converted physical address. 
Such a virtual cache can be used as an internal storage 
unit in high-performance systems, more particularly a 
high-performance microprocessor. 

15 General ly, caches are used to improve the 

performance of microprocessors. In particular, a virtual 
cache is used to increase the efficiency of a data 
storage unit. As a result, a virtual address is used 
internally, whereas it is converted into a physical 

20 address for accessing an external memory. 

Also, an internal or an external cache is usually 
accessed using the converted physical address. 

It is natural that the external cache should be 
accessed using the physical address. However, in the 

25 case where the internal cache is to be accessed using the 
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physical address, an address conversion operation must be 
performed, resulting in an increase in access time. 

In order to solve the above-mentioned problem, the 
internal cache has been used as a virtual cache which can 
5 be accessed directly using a virtual address. In such a 
virtual cache, internal data consistency must be secured. 
Also, the internal cache must be externally "snooped", 
according to a variation in the external cache or memory. 
Fig, 1 of the accompanying drawings is a block 

10 diagram illustrating the construction of a previously 
proposed microprocessor system. As shown in this 
drawing, the previously proposed microprocessor system 
utilizes a two-level cache system with internal and 
external caches 1 and 2, for the improvement in the 

15 performance thereof. As the external cache 1, a memory 
is used which is relatively low in cost and large in 
capacity, but which has a longer access time than the 
internal cache l. As the internal cache 1, a memory is 
used which is high in cost per unit, but which performs a 

20 high-speed operation to act up to the high operational 
speed of a processor (CPU) , 

Fig. 2 of the accompanying drawings is a block 
diagram illustrating one example of a multi-processor 
system using the processor in Fig. 1. As shown in this 

25 drawing, the mult i -processor system has to consider even 
the operation of other processors or bus masters. To 
this end, the multi-processor system requires an external 
bus to be monitored. Such an operation is typically 
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called "bus snooping* or simply "snooping" . The snooping 
is an important part of the data consistency in a 
multiprocessor system. 

Fig. 3 of the accompanying drawings is a view 
5 illustrating a previously proposed conception of 

accessing a virtual cache using a virtual address VA and 
a physical address PA, in a processor employing the 
virtual cache as an internal cache. As shown in this 
drawing, a system employing a virtual memory uses the 

10 virtual address VA. The access time in the case of 

accessing the internal cache directly using the virtual 
address VA is considerably reduced as compared with that 
in the case of converting the virtual address VA into the 
physical address PA and accessing the internal cache 

15 using the converted physical address PA. However, in the 
case of accessing the internal cache directly using the 
virtual address VA, an operation is performed on an 
external bus according to the physical address PA. As a 
result/ bus snooping becomes an issue. 

20 Features of a dual-directory virtual cache to be 

described below, by way of example, in illustration of 
the invention are that it is capable of reducing access 
time to enhance the performance of a microprocessor, of 
allowing the associated system to employ a physical 

25 cache, and of providing a method for the control thereof. 

In a particular embodiment to be described below, by 
way of example, in illustration of the present invention, 
there is a cache memory accessed by a virtual address 
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from a microprocessor, the cache memory including a data 
memory storing data in cache lines, a virtual tag memory 
storing a virtual address tag, wherein the virtual tag 
memory is accessed by a request from a microprocessor in 
5 parallel with the data memory, a physical tag memory 

storing a physical address tag, wherein the physical tag 
memory is coupled to an address translation means and a 
bus monitoring logic circuit r and wherein the address 
translation means translates the virtual address into a 

10 physical address corresponding to the physical address 
tag, and a pointer associating the virtual address tag 
with the physical address tag. 

In another aspect to be described below by way of 
example, in illustration of the present invention, there 

15 is provided a method for accessing a cache memory using a 
virtual address in response to a request from a 
microprocessor including a bus monitoring logic circuit, 
including the steps of determining whether the virtual 
tag corresponding to the virtual address is stored in a 

20 first memory, so that either a hit signal or a miss 

signal is generated, determining whether a state of a 
cache line in a first memory storing data is valid in the 
case where the hit signal is generated, performing a read 
or a write operation in the case where the state of the 

25 cache line is valid, translating the virtual address into 
a physical address in the case where the state of the 
cache line is invalid, determining whether a physical tag 
corresponding to the physical address is stored in a 
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second memory, copying the state bits of the physical tag 
into the first memory, if the corresponding physical tag 
exists in the second memory, and performing a read or a 
write operation, selecting entries to be replaced in the 
5 first memory in the case where there is not a 

corresponding physical address in the second memory, or 
the miss signal is generated, determining whether there 
are entries in the second memory, which correspond to the 
entries to be replaced in the first memory, and, if there 
10 are not, the entries to be replaced in the second memory, 
re-selecting other entries to be replaced in the second 
memory and selecting the corresponding entries to be 
replaced in the first memory according to the re-selected 
entries, and reading a new cache line from the external 
15 memory and performing a read or a write operation- 

Arrangements for use in illustrating the invention 
will now be described, by way of example, with reference 
to Figs, 4 to 6 of the accompanying drawings, in which: 

Fig. A is a block diagram illustrating the 
20 construction of a dual-directory virtual cache, 

Fig* 5 is a flowchart illustrating the operation of 
the dual-directory virtual cache shown in Fig. 4 which is 
performed in response to a request from a processor, and 

Fig. 6 is a flowchart illustrating the operation of 
25 the dual-directory virtual cache shown in Fig. A which is 
performed in response to a request from a bus monitoring 
logic circuit. 

First, Fig. 4 is a schematic diagram showing an 
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internal cache. As shown in Fig. A, the internal cache 
may be classified into three parts. That is, the 
internal cache memory is a dual-directory virtual cache 
system including a P-tag memory 41 f a V-tag memory 42 and 
5 a data memory 43, 

A CPU normally accesses the V-tag memory 42 using 
virtual addresses, and a bus monitoring logic in the CPU 
accesses the P-tag memory 41 using physical addresses in 
order to perform a bus snooping operation. The data 

10 memory having actual data is accessed by the CPU through 
the virtual address in parallel with the V-tag memory 42. 

The P-tag memory 41, which takes charge of the bus 
snooping operation, may compare the address in the 
internal cache with addresses on the bus as quickly as 

IS possible, and then access the data. The V-tag memory 42 
is accessed by the CPU, together with the data memory 43, 
so as to respond quickly to its request. 

The P-tag memory 41 has a tag for each cache line in 
the data memory 43 (the cache line is the size of the 

20 data which is transmitted between the cache and a main 
memory at one time, and the tag is data information to 
identify whether the cache data corresponds to the 
address, and typically the tag consists of high level 
addresses) ♦ Each tag has unique information which 

25 corresponds to the data in the data memory 43. Since P- 
tag memory 41 includes a table of the pointer for the 
data memory 43, it has the advantage in that there is no 
need for it to have association with the V-tag memory 42 
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and the data memory 43. 

The true state of the data for each line of the 
cache is maintained in the P-tag memory 41. Also, the V- 
tag memory 42 maintains a little information for each 
5 line. However, valid data can be considered as a invalid 
data in the V-tag memory 42, because the item in the V- 
tag memory 42 is made invalid in the case where a 
specific event, such as a task switch, or a change of 
page table, takes place. This means that the address 

10 mapping from the virtual address to the physical address 
is invalid. After accessing the data, the CPU must 
perform a verification process , 

Therefore, two types of misses may be created in the 
V-tag memory* One of them is a "no-match miss" as a 

15 result of the absence of data. The other is an "invalid 
miss H necessary to map the virtual address to a new 
physical address, although the data is valid. Also, each 
tag memory 41 and 42 has pointer information to connect 
the virtual address to the physical address. 

20 I* the arrangement described, the CPU requests 

access to the V-tag memory 42 and to the data memory 43. 
if an invalid miss occurs, an address translation is 
carried out from a virtual address to a physical address. 
The translated physical address goes to the P-tag memory 

25 41. if it is proved that there is corresponding data in 
the data memory 43, the information state in the P^tag 
memory 41 is copied into the specific location in the V- 
tag memory 42. By doing so, the "invalid miss" is 
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processed like a M hit". 

When a n no-match miss" occurs/ the physical address 
is obtained through the address translation, and after 
selecting a replacement target, the corresponding 
5 external memory operation takes place. 

The snooping (monitoring) logic circuit compares all 
address on the bus with the P-tag memory 41. At this 
time, in the case where there is an address corresponding 
to the P-tag memory 41, different events can occur in the 
10 snooping logic circuit as follows: 

1) It makes the data invalid and makes the item in 
the P^tag memory 41 and V-tag memory 42 invalid* 

2) In the case where it should drive the data into 
the exterior, it drives the data into the exterior using 

15 the pointer in the P-tag memory 41, and, if necessary/ it 
changes the state of the cache line to be associated with 
the drive , 

3) It reads data on the bus so that it updates the 
data memory, changing the state of the cache line. 

20 The dual-directory virtual cache will now be 

illustrated with reference to Figs. 5 and 6. 

First, Fig. 5 is a flowchart illustrating the 
operation of the dual-directory virtual cache in Fig. 4 
which is carried out in response to a request from a 
25 processor. 

First, the CPU determines whether the virtual 
address, in response to the request, is stored in the V- 
tag memory. That is, "hit /miss" is inspected using the 
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virtual address, at step 51. If the virtual address 
corresponding to the request from the CPU is stored in 
the V-tag memory, a hit signal is generated so that the 
state of the corresponding cache line is inspected at 
5 step 52. In the case where the state of the cache line 
is valid, the conventional operation (write or read) , 
according to the request, is performed at steps 56 to 60. 
In the case where the state of the cache line is invalid, 
the virtual address is, at step 53, translated into a 

10 physical address by a translation look-aside buffer (TLB) 
so that the translated physical address is inspected in 
the P-tag memory at step 54 . 

If a corresponding physical tag exists in the P-tag 
memory, the state information, which the corresponding P- 

15 tag indicates, is copied into the V-tag entry at step 55, 
and the write or read operation is performed at steps 56, 
as described above . 

In the case where there is not a corresponding 
physical tag in the P-tag memory at step 54, or the miss 

20 signal is generated at step 51, the PU selects, at step 

61, entries to be replaced in the V-tag memory, and 
determines whether there are corresponding (associated by 
a pointer) entries in the P-tag memory, or not, at step 

62. If there are corresponding entries in the P-tag 

25 memory, the CPU, at step 65, examines whether the cache 
line is valid and the cache line has been modified. In 
the Case where the cache line is valid and has been 
modified, the CPU writes the corresponding cache line in 
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an external memory at step 66. 

At step 62, if there are not corresponding entries 
in the P-tag memory, the CPU re-selects other entries to 
be replaced in the P-tag memory at step 63 and, at step 
S 64, selects, in the V-tag memory, the V-tag entries 

corresponding to the selected P-tag entries, and performs 
steps 65 and 6 6 with respect to the selected V-tag 
entries. By doing so, the CPU updates the v-tag and P- 
tag memories, and carries out the read or write operation 
10 using the external data at steps 56 to 60. 

Fig, 6 is a flowchart illustrating the operation of 
the dual-directory virtual cache shown in rig. 4 which is 
performed in response to a request from a bus monitoring 
logic circuit. 

15 The bus monitoring logic circuit examines whether 

there is a tag corresponding to the input physical 
address signals in the P-tag memory at step 81. If there 
is a corresponding tag in the P-tag memory, the bus 
monitoring logic circuit examines the bus operation at 

20 step 82. 

In the case of a read operation, according to the 
state of the cache line, such as "invalid (I)", 
"modification (M) M and "share <S) W , the data stored in 
the cache memory may be provided to the external bus and 

25 the state of the provided cache line, which is varied as 
a cache memory read operation, is typically performed by 
the conventional monitoring logic circuit. That is to 
say, if the state of the requested cache line is 
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"modification (M) " the data is written in the external 
memory and the state of the requested cache line is 
changed into the "share (S) 11 state at steps 85 and 86* 

In the case of a write operation, the data stored in 
5 the cache memory should be made invalid. However, the 
write-back operation may be performed according to the 
state of the cache line at step 83. In particular, in 
the case where the state of the cache line is the 
"modification" state, the corresponding data should be 
10 write back in external memory and then the state is 

changed into the "invalid" state because the cache line 
having the "modification" state has the updated 
information. 

Furthermore, when the entries in the P~tag memory 
IS are in the "invalid" state, the corresponding entries in 
the V-tag memory must also be brought into the "invalid" 
state, using a P-tag pointer. 

As is apparent from the above description, the 
arrangements described provide a virtual address tag 
20 memory, together with the physical address tag memory, to 
the internal cache memory, thereby minimizing the time 
required in the address translation and thus improving 
the performance of the microprocessor , 

Although preferred embodiments illustrative of the 
25 invention have been disclosed by way of example, those 
skilled in the art will appreciate that various 
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modifications, additions and substitutions are possible, 
without departing from the scope of the protection sought 
by the accompanying claims. 
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13 
CLAIMS 



1- A cache memory accessed by a virtual address 
from a microprocessor , the cache memory including a data 
5 memory for storing data in cache lines thereof, a virtual 
tag memory for storing a virtual address tag, wherein the 
virtual tag memory is accessed by a request from a 
microprocessor in parallel with the data memory, a 
physical tag memory for storing a physical address tag, 

10 wherein the physical tag memory is coupled to an address 
translation means and a bus monitoring logic circuit, and 
wherein the address translation means translates the 
virtual address into a physical address corresponding to 
the physical address tag, and a pointer associating the 

IS virtual address tag with the physical address tog. 

2. A cache memory as claimed in claim 1, wherein 
the microprocessor includes a plurality of multiplexing 
means for copying state information in the physical tag 

20 memory into the virtual tag memory and updating the 
virtual tag memory and the physical tag memory. 

3. A cache memory as claimed in claim 1, wherein 
the bus monitoring logic circuit makes the data invalid, 

25 and makes the corresponding items invalid in the virtual 
tag memory and the physical tag memory. 

4. A method for accessing a c ache memory using a 
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virtual address in response to a request from a 
microprocessor, including the steps of storing data in 
the cache lines of a data memory, storing a virtual 
address tag in a virtual tag memory wherein the virtual 
5 tag memory is accessed by a request from a microprocessor 
in parallel with the data memory , storing a physical 
address tag in a physical tag memory wherein the physical 
tag memory is coupled to an address translation means and 
a bus monitoring logic circuit and wherein the address 
10 translation means translates the virtual address into a 
physical address corresponding to the physical address 
tag, and associating the virtual address tag with the 
physical address tag by means of a pointer, 

i5 5. A method for accessing a cache memory vising a 

virtual address in response to a request from a 
microprocessor having a bus monitoring logic circuit, 
including the steps of determining whether the virtual 
tag corresponding to the virtual address is stored in a 

20 first memory, so that either a hit signal or a miss 

signal is generated, determining whether the state of a 
cache line in a first memory storing data is valid in the 
case where a hit signal is generated, performing a read 
or a write operation in the case where the state of the 

25 cache line is valid, translating the virtual address into 
a physical address in the case where the state of the 
cache line is invalid, determining whether a physical tag 
corresponding to the physical address is stored in a 
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second memory, copying state bits of the physical tag 
into the first memory if there exists a corresponding 
physical tag in the second memory and performing a read 
or a write operation, selecting entries to be replaced in 
5 the first memory in the case where there is not a 

corresponding physical address in the second memory or a 
miss signal is generated, determining whether there are 
entries in the second memory, which correspond to the 
entries to be replaced in the first memory, and/ if there 

10 are not, determining the entries to be replaced in the 

second memory, re-selecting other entries to be replaced 
in the second memory and selecting the corresponding 
entries to be replaced in the first memory according to 
the re-selected entries, reading a new cache line from 

15 the external memory and performing a read or a write 
operation. 

6. A method as claimed in claim 5/ wherein the 
second memory is accessed by the bus monitoring logic 

20 circuit, using a physical address on a bus master. 

7. A method as claimed in claim 6, wherein the bus 
monitoring logic circuit changes the state information of 
the physical tag and wherein the state information of the 

25 virtual tag is changed by the changed state information 
of the physical tag* 

B. A method as claimed in claim 5, wherein the 
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step of reading the new cache line from the external 
memory includes the step of writing a modified cache line 
in an external memory . 

5 9. A method as claimed in claim 8, wherein the 

external memory is an external cache memory. 

10. A method as claimed in claim 8, wherein the 
external memory is a main memory. 

10 

11. A method as claimed in claim 5, wherein the 
first memory has pointer information which associates the 
virtual tag with the physical tag. 

15 12. A method as claimed in claim 11 r wherein the 

second memory has pointer information which associates 
the physical tag with the virtual tag. 

13. A cache memory as claimed in claim 1 

20 substantially as described herein with reference to any 
one of Figs. 4 to 6 of the accompanying drawings. 

14. A method as claimed in either claim 4 or claim 
5 substantially as described herein with reference to any 

25 one of Figs. 4 to 6 of the accompanying drawings. 
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